python - 在python中模拟文件对象或iterables
全部标签 我正在尝试使用ruby脚本为MacOS上的文件设置文件系统创建时间。在MacOSX上,'ctime'表示inode的最后一次修改时间而不是文件创建时间,因此使用ruby的File.utime()来设置ctime将无济于事。使用这个提示[http://inessential.com/2008/12/18/file_creation_date_in_ruby_on_macs]我可以检索文件的创建时间:Time.parse(`mdls-namekMDItemContentCreationDate-raw"#{filename}"`)...但是知道如何使用ruby设置它吗?--更新
尝试打开文件时,我不断收到此Nosuchfileordirectory错误。我在做:file=open("http://farm7.static.flickr.com/6064/6090089285_242ca0e342_m.jpg")根据ruby-doc并不断收到这样的错误。我做错了什么? 最佳答案 你必须require'open-uri'不需要'open-uri',我在我的irb中得到了这个确切的错误消息:Errno::ENOENT:Nosuchfileordirectory 关于R
我有一个开始有重复代码的config.ru文件:map'/route1'dorunSampleApp.newendmap'/route2'dorunSampleApp.newend我想把这个config.ru文件变成它自己的Rack应用程序,这样我所要做的就是:map'/'dorunMyApp.newend创建自己的Rack应用程序的正确方法是什么?具体来说,我如何创建一个类,以便我可以在我的类中使用map方法来定义一堆路由?解决方法:这是一个可行的解决方案:classMyAppdefinitialize@app=Rack::Builder.newdo#copycontentsofyo
我有一个使用反引号的方法,但stub不适用于它。它正在拉取ls的结果:classTestHelperdefself.test_method`ls`endendrspec测试:describeTestHelperdodescribe'.test_method'dosubject{described_class.test_method}before{Kernel.stub(:`).and_return("test_dir")}it{expect(subject).toeql("test_dir")}endend 最佳答案 TestHel
这只是一个关于最佳实践的问题。假设您有一个采用一个参数的方法。这个参数是一个对象的id。理想情况下,我希望能够直接传递对象的ID,或者只传递对象本身。最优雅的方法是什么?我想到了以下内容:defmethod_nameobjectobject_id=object.to_param.to_i###dowhateverneedstobedonewiththatobject_idend因此,如果参数已经是一个id,它几乎保持不变;如果它是一个对象,它会得到它的ID。这行得通,但我觉得这可能会更好。此外,to_param返回一个字符串,在某些情况下它可能返回一个“真实”字符串(即“string”
如果我使用OpenURI运行一个简单的脚本,我可以访问网页。结果写入终端。通常我会使用bash重定向将结果写入文件。如何使用ruby将OpenURI调用的结果写入文件? 最佳答案 require'open-uri'open("file_to_write.html","wb")do|file|URI.open("http://www.example.com/")do|uri|file.write(uri.read)endend注意:在Rubyopen(url)而不是URI.open(url)。参见https://bugs.ruby
是否所有文件都在具有文件夹结构(类似于java包)的模块中的ruby约定?例如,如果我的文件结构如下所示库/人/工具此处的文件是否具有如下模块结构:modulePeoplemoduleUtils#somefunctionalityforPeople::Utilsendend我问的原因是因为我一直在阅读一些Rails代码,并且似乎有几个文件在这样的文件结构中,但没有任何模块声明。我猜这是为了让您可以使用效用函数而不必包含People::Utils。ruby是否有关于何时应该使用模块以及何时不应该使用模块的约定? 最佳答案 这是Ra
ActiveRecord安全supportsdup,但mongoid似乎无法正确处理它。我想做以下事情:x=MyModel.newx.savey=x.dupy.savey应该是一个全新的对象,这样:x!=yx.id!=y.id 最佳答案 试试这个:x=Item.newx.savey=x.cloney.save它应该更改_id并复制所有其他字段。我注意到这似乎不适用于嵌入式文档。对于原始文档中的每个嵌入式文档,它会在克隆中使用新ID创建一个空白的嵌入式文档,但不会填充任何其他字段。如果使用嵌入式文档,最好编写自己的类方法。
听起来很简单,但这似乎是一项异常复杂的任务。 最佳答案 如果您使用的是aws-s3gem,则以下代码会将存储桶BUCKET_NAME中的文件夹OLD_FOLDER_NAME重命名为NEW_FOLDER_NAME:bsize=OLD_FOLDER_NAME.sizebucket=AWS::S3::Bucket.find(BUCKET_NAME)bucket.objects({:prefix=>OLD_FOLDER_NAME}).eachdo|o|AWS::S3::S3Object.rename(o.key,NEW_FOLDER_NAM
我有一个属性数组如下,attributes=["test,2011","photo","198.1x198.1cm","Photo:ManuPKFullScreen"]当我这样做时,artist=attributes[-1].gsub("Photo:")partist我在终端中得到以下输出#想知道为什么我得到一个枚举器对象作为输出?提前致谢。编辑:请注意,我做的不是attributes[-1].gsub("Photo:",""),而是attributes[-1].gsub("Photo:")所以想知道为什么枚举器对象返回到这里(我期待一条错误消息)以及发生了什么。?ruby-1.9.2